import tool.TreeNode;

import java.util.LinkedList;
import java.util.Queue;

/**
 * 给你一个二叉树的根节点 root。设根节点位于二叉树的第 1 层，而根节点的子节点位于第 2 层，依此类推。
 * 请你找出层内元素之和 最大 的那几层（可能只有一层）的层号，并返回其中 最小 的那个。
 * <p>
 * 示例 1：
 * 输入：root = [1,7,0,7,-8,null,null]
 * 输出：2
 * 解释：
 * 第 1 层各元素之和为 1，
 * 第 2 层各元素之和为 7 + 0 = 7，
 * 第 3 层各元素之和为 7 + -8 = -1，
 * 所以我们返回第 2 层的层号，它的层内元素之和最大。
 * <p>
 * 示例 2：
 * 输入：root = [989,null,10250,98693,-89388,null,null,null,-32127]
 * 输出：2
 * <p>
 * 提示：
 * 树中的节点数介于 1 和 10^4 之间
 * -10^5 <= node.val <= 10^5
 * <p>
 * 来源：力扣（LeetCode）
 * 链接：https://leetcode-cn.com/problems/maximum-level-sum-of-a-binary-tree
 * 著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
 */
public class Q01161m {
    public int maxLevelSum(TreeNode root) {
        int ans = 0, depth = 0, maxSum = -10_0001, size;
        Queue<TreeNode> fifo = new LinkedList<>();
        fifo.offer(root);
        while ((size = fifo.size()) > 0) {
            depth++; // 访问到当前层
            int currSum = 0;
            while (size-- > 0) {
                root = fifo.poll();
                currSum += root.val; // 求同层的和
                if (root.left != null) {
                    fifo.offer(root.left);
                }
                if (root.right != null) {
                    fifo.offer(root.right);
                }
            }
            if (currSum > maxSum) { // 发现更大和
                ans = depth;
                maxSum = currSum;
            }
        }
        return ans;
    }
}
